//引入包
const path = require('path');
//引入html插件
const HTMLWebpackPlugin = require('html-webpack-plugin')
//引入clean插件
const {CleanWebpackPlugin} = require('clean-webpack-plugin')

//webpack 中配置信息
module.exports = {
    //指定入口文件
    entry:"./src/index.ts",
    //指定打包文件所在目录
    output:{
        path:path.resolve(__dirname,'dist'),
        //打包文件的名字
        filename:"bundle.js",
        //配置打包环境
        environment:{
            arrowFunction:false//不用箭头函数
        }
    },
    //指定打包所使用的模块
    module:{
        //指定加载规则
        rules:[
            {
               test:/\.ts$/,//规则生效文件
               use:[//要使用的loader
               //配置babel
                    {
                        //指定加载器
                        loader:'babel-loader',
                        //设置babel
                        options:{
                            //设置预定义环境
                            presets:[
                                [
                                    //指定环境插件
                                    "@babel/preset-env",
                                    //配置信息
                                    {
                                        targets:{//要兼容的浏览器
                                            "chrome":"88",
                                            "ie":"11"
                                        },
                                        //指定corejs版本
                                        "corejs":"3",
                                        //使用corejs的方式 "usage" 按需加载
                                        "useBuiltIns":"usage"
                                    }
                                ]
                            ]
                        }
                    },
                'ts-loader'
                ], 
               //指定要排出的文件
               exclude:/node_modules/
            },
            //配置less文件的处理
            {
                test:/\.less$/,
                use:[
                    "style-loader",
                    "css-loader",
                    //引入postcss
                    {
                        loader:"postcss-loader",
                        options:{
                            postcssOptions:{
                                plugins:[
                                    [
                                      "postcss-preset-env",
                                      {
                                        browsers:'last 3 versions'
                                      }  
                                    ]
                                ]
                            }
                        }
                    },
                    "less-loader"
                ]
            }
        ]
    },
    plugins:[//插件
        new HTMLWebpackPlugin({
            // title:"这是我的标题",
            template:"./src/index.html"
        }),
        new CleanWebpackPlugin()
    ],
    mode:'development', // 设置mode
    //设置引用模块
    resolve:{
        extensions:['.ts','.js']
    }
}